<!DOCTYPE html>
<html lang="en">

<head>
    <meta charset="UTF-8">
    <meta http-equiv="X-UA-Compatible" content="IE=edge">
    <meta name="viewport" content="width=device-width, initial-scale=1.0">
    <title>Document</title>
</head>

<body>
    <script>
        // 异步 
        console.log(111);

        // 定时器当中 第一个参数 回调函数！- 异步的！
        // 宏任务 慢！
        // 微任务 快！

        // 异步错误不能直接放到try内去捕获
        // try{
        //     setTimeout(() => {
        //         // console.log(3333);
        //         a()
        //     }, 0);
        // }catch(err){
        //     console.log(err);
        // }

        setTimeout(() => {
            try{
                // console.log(3333);
                a()
            }catch(err){
                console.log(err);
            }
        }, 0);

        console.log(2222);

        // 异步代码放到try内 无法捕获异步错误
        // try
            // setTimeout() 
        // catch()
        // finally
        

        // 正确方式 将try 放入异步回调函数内执行

        // 在代码最后执行完成后执行的函数 都是异步执行函数
        console.log("同步结束");
    </script>
</body>

</html>